$(function () {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
    // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)

    //为上传按钮绑定点击事件
    $("#btnChooseImage").on("click", function () {
        $("#file").click();
    });
    //为文件选择框绑定change事件
    $("#file").on("change", function (e) {
        //获取用户选择的文件
        let filelist = e.target.files;
        if (filelist.length === 0) {
            return layui.layer.msg("请选择要上传的文件！");
        }
        //拿到用户选择的文件（文件信息对象，不包含数据和物理路径）
        let file = e.target.files[0];
        //将文件，转化为路径（创建文件虚拟路径）
        let newImgURL = URL.createObjectURL(file);
        $image
            .cropper('destroy')      // 销毁旧的裁剪区域
            .attr('src', newImgURL)  // 重新设置图片路径
            .cropper(options)        // 重新初始化裁剪区域
    });

    $("#btnUpload").on("click", function () {
        //拿到用户裁剪之后的数据（base64编码字符串）
        var dataURL = $image
            .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
                width: 100,
                height: 100
            })
            .toDataURL('image/png')       // 将 Canvas 画布上的内容，转化为 base64 格式的字符串

        //发起ajax请求
        $.ajax({
            method: "POST",
            url: "/my/update/avatar",
            data: {
                avatar: dataURL
            },
            success: function (res) {
                if (res.status !== 0) {
                    return layui.layer.msg("更新头像失败！");
                }
                layui.layer.msg(res.message);
                window.parent.getUserInfo();
            }
        });
    });
});